package com.example.demo.utils;

import lombok.extern.slf4j.Slf4j;

import java.math.BigInteger;
import java.security.MessageDigest;

/**
 * @description:
 * @author: cj
 * @create: 17-12-21 17:56:41
 */
@Slf4j
public class MD5Utils {


    /***
     * MD5加码 生成32位md5码
     */
    public static String string2MD5(String inStr) {
        MessageDigest md5 = null;
        try {
            md5 = MessageDigest.getInstance( "MD5" );
        } catch (Exception e) {
            log.info( e.toString() );
            e.printStackTrace();
            return "";
        }
        char[] charArray = inStr.toCharArray();
        byte[] byteArray = new byte[charArray.length];

        for (int i = 0; i < charArray.length; i++) {
            byteArray[i] = (byte) charArray[i];
        }

        byte[] md5Bytes = md5.digest( byteArray );
        StringBuffer hexValue = new StringBuffer();
        for (int i = 0; i < md5Bytes.length; i++) {
            int val = ((int) md5Bytes[i]) & 0xff;
            if (val < 16) {
                hexValue.append( "0" );
            }

            hexValue.append( Integer.toHexString( val ) );
        }
        return hexValue.toString();

    }

    /**
     * 加密解密算法 执行一次加密，两次解密
     */
    public static String convertMD5(String inStr) {

        char[] a = inStr.toCharArray();
        for (int i = 0; i < a.length; i++) {
            a[i] = (char) (a[i] ^ 't');
        }
        String s = new String( a );
        return s;

    }

    /**
     * 判断输入的密码和数据库中保存的MD5密码是否一致
     *
     * @param inputPassword 输入的密码
     * @param md5DB         数据库保存的密码
     * @return
     */
    public static boolean passwordIsTrue(String inputPassword, String md5DB) {

        String md5 = string2MD5( inputPassword );
        return md5DB.equals( md5 );
    }

    public static String getMD5String(String str) {
        try {
            // 生成一个MD5加密计算摘要
            MessageDigest md = MessageDigest.getInstance( "MD5" );
            // 计算md5函数
            md.update( str.getBytes() );
            // digest()最后确定返回md5 hash值，返回值为8位字符串。因为md5 hash值是16位的hex值，实际上就是8位的字符
            // BigInteger函数则将8位的字符串转换成16位hex值，用字符串来表示；得到字符串形式的hash值
            //一个byte是八位二进制，也就是2位十六进制字符（2的8次方等于16的2次方）
            return new BigInteger( 1, md.digest() ).toString( 16 );
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    // 测试主函数
    public static void main(String args[]) {
        String md5String = getMD5String( "123" );
        System.out.println( md5String );
        String s = new String( "123456" );
        log.info( "原始：" + s );
        log.info( "MD5后：" + string2MD5( s ) );
        log.info( "密码是否一致：" + passwordIsTrue( "123456", "e10adc3949ba59abbe56e057f20f883e" ) );

    }

}
